This an initial beta release, and as such is neither easy to use, nor very brilliant.
If you have the time and patience it provides functionality, but nowt else.
At the time of release, I still do not know how to write out an IFF-ILBM, or how to open up an Amiga display. At the moment the program can only read and write 24bit BMP files.
So in order to use it you will have to convert the output file into an IFF file with some other image conversion software (Image Studio etc). I'm currently reading all I can about such things, so if I get any kind of response I'll make a proper release that addresses these basic issues.
This beta release was released primarily to see if there was any interest in this kind of dithering technique. If you like the way it makes your pictures look, (or if you use it at all), please contact me at one of the addresses at the end of this document with your comments. If you are a coder yourself and have any information about IFF-ILBM's / opening custom screens or other Amiga related stuff, please please please send me a mail, so that I can make a decent version.
If you have coded any image manipulation software and would like to include a dither like the one used here, please feel free to do so. I only ask that if you do, please send me a fully registered copy of your program, and an email/note explaining that you got the idea from my program. (It would be nice if you mentioned my name in the documentation too).
USAGE: Ham32k <inputfile> [outputfile]
Where inputfile is the full filename of your 24 bit colour BMP.
The outputfile is optional, if omitted the output will be called <inputfile.32k>
LIMITATIONS:
This program is quick and dirty. It reads only the bare minimum of the BMP header, (dimensions) and so can not cope with 256 colour BMP's (So no compression either). At the moment there is no support for any other file type. (I had to reverse engineer the BMP format to get this far!).
FUTURE:
Where can I start? Obviously save as IFF-ILBM and display without saving.
JPEG and GIF support would be nice.
If anybody thinks it's a good idea, I might include the ability to save the files in a bespoke 15bit RLE save format, which should result in much less disk space being used than either the 24bit BMP, or a double size 12bit IFF.
Speed improvements on the disk read/writes.
Unfortunately I have no plans on releasing a 68020+ version. (What would be the point, if you have got an 020, you probably have AGA too).
REQUIREMENTS:
The actual conversion program requires very little ram at all.
To display/store the resultant picture you generally will need twice as much disk space and chip memory as you needed for the normal picture.
This program was developed on an Amiga 500+ with 4meg fast 1meg chip 0.5meg slow. OS version 2.04 .
It should in theory work on any Amiga, as it makes no OS specific calls whatsoever, but I haven't tested it on any machine apart from my own, so I make no guarantees.
If it doesn't work on your machine, that's just too bad.
It allows a standard OCS/ECS Amiga to view 24bit BMP pictures in glorious pseudo 15 bit (32000 colours), instead of the usual 12 bit (4096 colours).
It is all a big con because:
Actually all that it does it perform a very simple dither operation on the BMP, in order to fool the eye in believing that it is seeing 15bit colour instead of the actual 12 bits displayed.
Why should you use it?
As far as I know, no other paint/image processing software can display images with this type of dither.
What is so special about this dither?
This dither program does not corrupt the image, like most other dithers. (I'm talking about that speckle affect). In order to give the illusion of more colours, most dithering algorithms have to lose image quality in the form of resolution. This is more noticeable in ordered dithers, than with non-ordered dithers, but the effect is still there. This dither does not lose any image quality.
How it does it:
Each 15bit-colour pixel value is divided equally into two 12 bit values. These are saved as top, and bottom component pixels thus doubling the vertical resolution. You then view this file in HAM interlaced mode to compensate for the changed aspect ratio. (1:2)
Confused? You will be.
(Maths explanation, even more confusing)
A 24bit(16 Million value) colour picture is compromised of 3 8bit(256 value) channels, one each for the 3 primary colours. An OCS/ECS Amiga is only capable of displaying 12Bit (4096 value) colour. This is 4bits (16 values) per colour channel. If you add 2 4bit values together you get a 5bit answer.
e.g.
16 + 16 = 32
4bit 4Bit 5Bit
Apply that to all three colour channels = 15bit (5+5+5).
Instead of 12bit (4+4+4).
How does that work out in real life?
You get an interlaced HAM screen made up of pairs of lines, with the top line of the pair holding one half of the 15bit pixel, and the bottom line holding the other half of the 15 bit pixel. When displayed in HAM interlaced mode the image appears to be have 32000 colours. This is much nicer on the eye than 12bit colour; flesh tones and shading appear especially nicer. Despite what you may think, there is very little flicker, even though you are using an interlaced screen mode. The reason for this is because the top and the bottom pixels of each pair are almost exactly the same brightness value. Most of the flicker incurred with interlaced screens comes from high contrast borders between adjacent scan lines.
Summary of Code (for programmers).
Action performed on each 8bit colour component.
For the top half of each 2 pixel pair: Output = Input masked to 4 bits.
For the bottom half: If bit 3 is set then output = input masked to 4 bits + 1,
else = input masked to 4 bits.
The brighter half of each 15bit pixel is actually alternated between the top and the bottom components every adjacent pixel. This is to minimise interlace flicker.
Downsides:
Because the image size is doubled, you will need twice as much chip ram to view any one picture, than before. Because of this, and because you are using a higher resolution viewing mode, it takes longer to display the image.
(Also in this beta release you will need twice as much hard disk space per picture).
But, the improvement that 15 bit colour makes over 12 bit, can make this an acceptable sacrifice (depending on the image type, shading effects, your personal preference etc).
---
To keep the archive size small I am not going to include any example pictures. However I do plan to separately upload some example pictures if you want to see the difference.
I will not be held responsible for any damage that my code causes to your machine.
LEGAL:
I reserve the copyright on the actual code used in this program, however you are free to distribute this software in any way that you like. Refer to the top of the document for usage rights.
I reserve the right to change, modify, or completely remove this software from public distribution at any time and for any reason.
BMP, IFF, JPG, GIF, AMIGA, ... Are all copyrighted to their various owners.
Imagestudio is a great piece of shareware (available on Aminet), get it today.
Apologies to anyone who I haven't mentioned who holds a copyright on a product that I have mentioned in this document.
CONTACT:
Email: chandlerbing@england.com
or samprice@hotmail.com
(only if you receive no reply from the above address).